home
***
CD-ROM
|
disk
|
FTP
|
other
***
search
/
Game Programming in C++ - Start to Finish
/
GameProgrammingS.iso
/
developer_install
/
CEGUISDK-0.4.1-VC6-STLport.exe
/
{app}
/
include
/
CEGUITextUtils.h
< prev
next >
Wrap
C/C++ Source or Header
|
2005-06-04
|
6KB
|
165 lines
/************************************************************************
filename: CEGUITextUtils.h
created: 30/5/2004
author: Paul D Turner
purpose: Interface to a static class containing some utility
functions for text / string operations
*************************************************************************/
/*************************************************************************
Crazy Eddie's GUI System (http://www.cegui.org.uk)
Copyright (C)2004 - 2005 Paul D Turner (paul@cegui.org.uk)
This library is free software; you can redistribute it and/or
modify it under the terms of the GNU Lesser General Public
License as published by the Free Software Foundation; either
version 2.1 of the License, or (at your option) any later version.
This library is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
Lesser General Public License for more details.
You should have received a copy of the GNU Lesser General Public
License along with this library; if not, write to the Free Software
Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
*************************************************************************/
#ifndef _CEGUITextUtils_h_
#define _CEGUITextUtils_h_
#include "CEGUIBase.h"
#include "CEGUIString.h"
// Start of CEGUI namespace section
namespace CEGUI
{
/*!
\brief
Text utility support class. This class is all static members. You do not create instances of this class.
*/
class CEGUIEXPORT TextUtils
{
public:
/*************************************************************************
Constants
*************************************************************************/
static const String DefaultWhitespace; //!< The default set of whitespace
static const String DefaultAlphanumerical; //!< default set of alphanumericals.
static const String DefaultWrapDelimiters; //!< The default set of word-wrap delimiters
/*************************************************************************
Methods
*************************************************************************/
/*!
\brief
return a String containing the the next word in a String.
This method returns a String object containing the the word, starting at index \a start_idx, of String \a str
as delimited by the code points specified in string \a delimiters (or the ends of the input string).
\param str
String object containing the input data.
\param start_idx
index into \a str where the search for the next word is to begin. Defaults to start of \a str.
\param delimiters
String object containing the set of delimiter code points to be used when determining the start and end
points of a word in string \a str. Defaults to whitespace.
\return
String object containing the next \a delimiters delimited word from \a str, starting at index \a start_idx.
*/
static String getNextWord(const String& str, String::size_type start_idx = 0, const String& delimiters = DefaultWhitespace);
/*!
\brief
Return the index of the first character of the word at \a idx.
/note
This currently uses DefaultWhitespace and DefaultAlphanumerical to determine groupings for what constitutes a 'word'.
\param str
String containing text.
\param idx
Index into \a str where search for start of word is to begin.
\return
Index into \a str which marks the begining of the word at index \a idx.
*/
static String::size_type getWordStartIdx(const String& str, String::size_type idx);
/*!
\brief
Return the index of the first character of the word after the word at \a idx.
/note
This currently uses DefaultWhitespace and DefaultAlphanumerical to determine groupings for what constitutes a 'word'.
\param str
String containing text.
\param idx
Index into \a str where search is to begin.
\return
Index into \a str which marks the begining of the word at after the word at index \a idx.
If \a idx is within the last word, then the return is the last index in \a str.
*/
static String::size_type getNextWordStartIdx(const String& str, String::size_type idx);
/*!
\brief
Trim all characters from the set specified in \a chars from the begining of \a str.
\param str
String object to be trimmed.
\param chars
String object containing the set of code points to be trimmed.
*/
static void trimLeadingChars(String& str, const String& chars);
/*!
\brief
Trim all characters from the set specified in \a chars from the end of \a str.
\param str
String object to be trimmed.
\param chars
String object containing the set of code points to be trimmed.
*/
static void trimTrailingChars(String& str, const String& chars);
private:
/*************************************************************************
Data
*************************************************************************/
static String d_delimiters; //!< Current set of delimiters.
static String d_whitespace; //!< Current set of whitespace.
/*************************************************************************
Construction / Destruction
*************************************************************************/
/*!
\brief
Constructor and Destructor are private. This class has all static members.
*/
TextUtils(void);
~TextUtils(void);
};
} // End of CEGUI namespace section
#endif // end of guard _CEGUITextUtils_h_